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ASYNCHRONOUS DIGITAL SUBSCRIBER LINE (ADSL) 
RESOURCE PLANNING 

5 Field of the Invention 

The present invention generally relates to the provisioning of resources for a 
subscriber on an asynchronous digital subscriber line (ADSL) network. Particularly, the 
present invention relates to optimizing resource provisioning and, more particularly, to 
providing a system and method to efficiently and reliably manage and optimize resources 
10 needed to establish ADSL permanent virtual circuits (PVCs) between subscribers and Internet 
Service Providers (ISP) / Network Service Providers (NSP). 

N! Background of the Invention 

u h Computing has become an integral component in our daily lives — so much so, that it 

1% is nearly impossible to imagine not interfacing with some form of computing device in a 

given day. The proliferation of computing has helped spawn the development of extremely 
l& effective and pervasive communication technologies, such as local area networks, wide area 
networks, intranets, and the Internet. These communication technologies, much like 
computing, have become ingrained in our lives, as new industries and markets have sprung 
2£Q into existence to provide services and products using these communication technologies. As 
more consumers incorporated these communication technologies into their personal or 
business practices, more service providers have been created to provide the needed 
communications support. Today, a significant amount of information is being deployed 
through these communication technologies. As such, connectivity has become paramount to 
25 consumers. Coupled to connectivity, the speed at which the information may be accessed is 
an important factor that is considered by consumers when choosing a communications service 
provider. 

Service providers addressed the need for reliable and fast connectivity by developing 
new protocols that transfer data quickly and efficiently over existing public communication 
30 networks. For example, asynchronous transfer mode (ATM) and transmission control 

protocol/internet protocol (TCP/IP) are two protocols that realize the transfer of significant 
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amounts of data. Utilizing these protocols, new services, such as digital subscriber line 
(DSL) and asynchronous digital subscriber line (ADSL) were developed that offered 
participating users fast connectivity rates and integrated services. DSL and ADSL service 
providers exploit traditional public networks (e.g. telephone networks) by creating three 
distinct channels over a single twisted pair wire connecting a subscriber to the public 
network. These channels include a transmitting channel to transmit non-voice data, a 
receiving channel to receive non-voice data, and a voice channel to transmit and receive voice 
data. By using existing public networks, participating users are offered desired 
communications services without the need for new communications networks and costly 
equipment. 

Although averting costs and the expenditure of resources by using existing public 
networks, DSL and ADSL service providers face many challenges in implementing this 
service on existing public networks. Among these challenges is the provisioning of ADSL 
network resources for each subscriber. Provisioning is a process that yields an end-to-end 
permanent virtual circuit (PVC) between the subscriber and the Internet Service Provider 
(ISP)/Network Service Provider (NSP). Included in the provisioning process is the 
configuration of various ADSL network hardware to enable the ADSL network to recognize 
and service participating users. The ADSL network hardware employs a number of 
configuration variables to establish a PVC. These configuration variables include the Virtual 
Path Identifier (VPI) and the Virtual Circuit Identifier (VCI). The VPI and VCI variables are 
integers, that when used in combination provide unique identifiers for each VPC and, 
correspondingly, for each subscriber. Generally, the assignment of values for the VPI and 
VCI variables is performed randomly by the provisioning process (e.g. provisioning 
software). As such, it is very difficult to arbitrarily determine any VCI value or any VPI 
value once assigned. 

Even with the most advanced provisioning procedures, there exist great inefficiencies. 
For example, the random generation and assignment of ADSL network configuration 
variables causes several problems. In the case of a "hung" PVC (i.e. the situation where the 
provisioning system fails during provisioning or, alternatively, where the provisioning system 
cancels the provisioning of resources in midstream), already assigned VPI values and VCI 
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values are "locked-out" until they are reset manually. Such scenario results in less than 
optimal use of available provisioning resources. Alternatively, where the provisioning 
system cancels the provisioning for a given subscriber in midstream and decides to reinstate 
the provisioning process for that same subscriber (i.e. the situation where a subscriber decides 
5 to order ADSL services but changes his/her mind, and then subsequently re-subscribes to 
ADSL services), the ADSL network operator is left to manually search the logs of the 
provisioning system to determine which VCI and VPI values were originally assigned to the 
subscriber. Such process is extremely inefficient and draws upon valuable resources that 
could otherwise be better utilized. 
10 From the foregoing it is appreciated that there exists a need for systems and methods 

r 3 that provide deterministic configuration variables to better manage and optimize resources of 
J~ hung provisioning processes. Such a system and method has not been realized in the prior art. 

-be 

M Summary of the Invention 

151 The present invention provides a system and method to optimize ADSL network 

" resources when provisioning resources on an ADSL network. As part of the provisioning 
FU process, configuration variables are set to create a permanent virtual circuit (PVC). The PVC 
\% creates an end-to-end connection between participating users and cooperating Internet Service 
*J Providers (ISPs) and Network Service Providers (NSPs). The present invention offers 
20 systems and methods that provide deterministic configuration variables such that the value of 
a configuration variable can be easily calculated. 

In an illustrative implementation, the provisioning of resources on an ADSL network 
is performed by a network management system (NMS). The network management system 
comprises a computing application which is in communication with the various components 
25 of the ADSL network to create, configure, and manage PVCs for participating users. As part 
of establishing a PVC, the virtual path identifier (VPI) and virtual circuit identifier (VCI) are 
assigned values that provide a unique VPI/VCI combination which identifies each established 
PVC. In this implementation, the VPI value may be set by the NMS to a constant value (e.g. 
0-15) for a group of feasible VCI values and then incremented when the feasible VCI values 
30 have been exhausted. That is, the VPI may be set to a constant value of 2 for the feasible VCI 
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values, VCI = 33 to 1023) and be incremented by one (e.g. VPI = 3) when all feasible VCI 
values have been exhausted. Further, the VCI values may be calculated using a number of 
other PVC configuration values including, the subscriber connection position on components 
of the ADSL network (e.g. the connection position on the remote access multiplexer (RAM) 

5 that physically connects the subscriber to the ADSL network, or alternatively, the connection 
position on the central office digital subscriber line access multiplexer (CO DSLAM) which 
connects the RAM to an asynchronous transfer mode (ATM ) subnet). The deterministic 
nature of the VCI variable assists in correcting "hung" provisioning of resource, that is, 
provisioning processes that are aborted or have failed. In knowing the VPI value and 
10 calculating the VCI value, the NMS is better positioned to restart a "hung" provisioning 

r3 process, i.e. complete a partial PVC. As such, ADSL available network resources are 
optimized. 

Other aspects of the present invention are described below. 

\y 

l jlH Brief Description of the Drawings 

3 The foregoing summary, as well as the following detailed description, of ADSL 

fy network resource planning systems and methods in accordance with the present invention are 

11 further described with reference to the accompanying drawings. For the purpose of 

y illustrating the invention, like references numerals represent similar parts throughout the 

f 

20 several views of the drawings, it being understood, however, that the invention is not limited 
to the specific methods and instrumentalities disclosed. In the drawings: 

Figure 1 is a block diagram of an exemplary ADSL network operations and 
management system, in which aspects of the invention may be implemented; 

Figure 2 is a block diagram of an exemplary ADSL network in accordance with the 
25 present invention; 

Figure 2A is a block diagram of exemplary subscribers interacting with an exemplary 
RAM ADSL network component in accordance with the present invention; 

Figure 2B is a block diagram of an exemplary RAM ADSL network component 
cooperating with an exemplary CO DSLAM ADSL network component in accordance with 
30 the present invention; 
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Figure 2C is a block diagram of an exemplary CO DSLAM ADSL network 
component cooperating with an exemplary ATM sub-net in accordance with the present 
invention; and 

Figure 3 is flow diagram of the processing performed by the resource planning system 
to provide deterministic configuration variables in accordance with the present invention. 

Detailed Description of Preferred Embodiments 

Overview 

Asynchronous Digital Subscriber Line (ADSL) converts existing twisted-pair 
telephone lines into access paths for multimedia arid high-speed data communications. With 
ADSL, the throughput of data varies depending on whether the subscriber is receiving or 
transmitting data from or to a cooperating network service provider (NSP). That is, in 
conventional ADSL systems, the subscriber can receive up to six megabits per second, and as 
much as 832 kilobits per second or more in both directions. Such rates expand existing 
access capacity by a factor of 50 or more without requiring new cabling. ADSL expands 
existing public information networks from one limited to voice, text and low resolution 
graphics to a powerful, ubiquitous system capable of supporting various forms of multimedia 
(e.g. streaming audio and video). 

Generally, an ADSL circuit connects an ADSL modem on each end of a twisted- 
telephone line, creating three information channels - a high speed downstream channel, a 
medium speed duplex channel (depending on the implementation of the ADSL architecture), 
and a POTS (Plain Old Telephone Service) or an ISDN channel. The POTS/ISDN channel is 
split off from the digital modem by filters, thus guaranteeing uninterrupted POTS/ISDN, even 
if ADSL fails. The high speed channel ranges from 1.5 to 6.1 megabits per second, while 
duplex rates range from 16 to 832 kilobits per second. Each channel can be submultiplexed 
to form multiple, lower rate channels, depending on the system. 

Given that the ADSL technology exploits existing public information networks, the 
demand for ASDL service is great and it is important to be able to efficiently and reliably 
provide ADSL to interested subscribers. Realizing that customer satisfaction is tantamount to 
success, network providers have been driven to develop new processes, hardware, and 
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software to better enhance a potential subscriber's experience when subscribing to the ADSL 
service. Furthermore, network providers have developed and are developing innovations 
which facilitate the internal provisioning of ADSL services to potential subscribers. Network 
providers are striving to reach a point where configuring and using ADSL services is as easy 
5 for a user as using today's analog dial-up technologies - if not easier. As such, ADSL service 
providers have developed automated processes that assist the subscriber in implementing and 
configuring ADSL equipment to realize ADSL services. 

Provisioning of ADSL services for a subscriber entails several steps including the 
configuration of various ADSL network hardware such that the ADSL network recognizes 
10 and services valid subscribers. The ADSL network cooperates with participating ISPs and 
r«i NSPs over an Asynchronous Transfer Mode (ATM) subnet. As such, certain ATM based 
j3 configuration variables must be configured during the ADSL services provisioning process. 
The provisioning of ADSL services yields an end-to-end permanent virtual circuit (PVC) 

12 between the subscriber (i.e. subscriber's computing device) and the Internet Service Provider 

. *~ 

lSf (ISPs) / Network Service Provider (NSPs). Such a process requires that the ADSL network 

f and the subscriber's equipment be provisioned in concert. Resources (e.g. ADSL network 

■ ?*= 

fU hardware and software) in the carrier's core ATM network connect the user's termination on 

the digital subscriber line access multiplexers (DSLAMs) to particular service providers. 
W Regardless of whether these resources are permanently configured or are set up on a per- 
20 session basis, each user's service must be configured to associate a given user with the 
service providers that the user is authorized to access. 

A permanent virtual circuit (PVC) is a means by which a user is associated with the 
correct service provider(s). The PVC comprises a plurality of configuration variables that are 
configured for each participating subscriber. These variables include the virtual path 
25 identifier (VPI) and the Virtual Circuit Identifier (VCI). The VPI is a number between 0-9 
that is included in the communication protocol header information and indicates the 
connectivity path of the subscriber. Likewise, the VCI is a number between 0-1023 that is 
included in ADSL communication protocol header information and indicates which channel 
on the ADSL hardware the PVC maintains its connection. The VPI and VCI may be used in 
30 combination to uniquely identify each subscriber of the ADSL network. During 
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provisioning, a subscriber is assigned a VPI and VCI combination which is stored as an entry 
in a translation table used to associate the VPI/VCI combination to a particular PVC. 

As ATM is a connection-oriented transfer mode, the virtual connection between 
source and destination has to be established before sending packets that carry user data. All 
packets of an established connection follow the same path within the network. As part of the 
VPC configuration each network switch generates an entry into the VPI/VCI translation table. 
This enables the switch to move an incoming packet from its VPI/VCI to corresponding 
outgoing VPI/VCI. In operation, when a packet is sent across the network, the VPI/VCI of 
the originating party is included in the header of the packet. As such, this kind of routing 
requires a relatively small header: only a locally valid address (i.e. VPI/VCI) has to be carried 
in the packet. 

The VPI/VCI designations are a key component of the provisioning process, in that 
they identify the virtual connection to the subscriber's line. These configuration values are 
provided and stored by the ADSL network management systems. Traditionally, the VPI/VCI 
configuration values are assigned non-deterministically — that is, they are assigned 
independently of the physical connection to the subscriber that the VPI/VCI values represent. 
Typically, the systems controlling the ADSL network will assign a random VPI value (from 
the available range of VPI values) and a random VCI value (from the available range of VCI 
values). This lends to a difficult re-animation process for failed or aborted provisioning 
procedures. Specifically, since these configuration variables are non-deterministic, the ADSL 
network operator is left to manually trace through configuration logs to determine the 
VPI/VCI values for the given failed or aborted provisioning procedure. This is a costly 
endeavor requiring the expenditure of time and labor. A more beneficial resource planning 
system would provide deterministic configuration variables that may be automatically 
calculated by the network management system that controls the allocation of such resources. 

The present invention seeks to ameliorate the shortcomings of existing ADSL 
resource provisioning systems and methods. In an illustrative implementation, the systems 
and methods of the present invention may be employed as part of an ADSL operations and 
management system. An exemplary ADSL operations and management system comprises a 
Look Qualification System (LQS), a Service Order Entry System (SOES), a Network 
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Management System (NMS) and an Element Management System (EMS). The LQS is used 
to determine if the ADSL network can deliver ADSL services to the participating user (e.g. 
interested subscriber). If qualified, the SOES procures and stores service information for the 
participating user. A portion of the collected service information is passed to the NMS to 
begin the provisioning of resources for the participating subscriber. The NMS uses service 
information to communicate with the ADSL network through the EMS. The EMS 
communicates with the ADSL network components through common communication 
protocols to set configuration variables and establish PVCs as per NMS instructions. 

In operation, the network management system communicates with ADSL network 
components to provision resources such to connect an interested subscriber (participating 
user) seeking ADSL services to an ADSL network providing such services. The process 
begins by physically connecting the subscriber to a remote accessing multiplexer (RAM) 
(The RAM may be housed and maintained at an ADSL network node local to the 
participating user). The NMS provides the RAM instructions for configuration of the first leg 
of the ADSL PVC. In addition, the NMS tracks and stores the configuration information for 
this first leg. Included in the configuration process of the first leg is the assignment of 
configuration variables for subscriber. For example, the PORTID configuration variable may 
be set. The PORTID configuration variable communicates to the NMS, the rack, shelf, card- 
slot, and port values that the participating subscriber has been given on the accepting RAM. 

The NMS communicates with the RAM to calculate and assign the VPI and VCI 
values to create the VPI/VCI unique combination for the PVC being created. The NMS 
employs various algorithms to calculate these values. Moreover, if needed (e.g. in the case of 
hung provisioning processes), these algorithms may be used by the NMS to re-calculate the 
VPI and VCI values. Further, the NMS communicates with the central office digital 
subscriber line access multiplexer (CO DSLAM) to set and ascertain additional configuration 
variables, such as, the ADSL port position on the CO DSLAM (Dpos). Lastly, the NMS 
communicates with the ATM subnet to which the CO DSLAM is connected to ascertain the 
ATM network port-id. Using all of these configuration variables, the NMS can provision 
these ADSL network components (i.e. resources on these ADSL network components) to 
create PVCs. 
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As will be described below with respect to Figures 1-4, the present invention is 
directed to systems and methods to optimize resource planning for ADSL services. In 
accordance with an illustrative implementation thereof, the present invention comprises a 
system and method to provide ADSL network operators with an enhanced network 
5 management system application that will employ deterministic configuration variables that 
drastically reduce the amount of resources required to re-animate the failed or aborted 
provisioning resources for ADSL services. 

In one embodiment, described more fully hereinafter, the system and method of the 
present invention may be implemented as part of a network management system of an ADSL 
10 network that cooperates with ADSL network components to provision resources for ADSL 
q services. Although the depicted embodiment contemplates a network management system 
application employing specific algorithms to produce deterministic configuration variables, 
=F those skilled in the art will appreciate that the inventive concepts described herein extend to 
H various computing application processes that produce deterministic variables that may be 
ijj used in the configuration of ADSL services on an ADSL network. 

RJ Illustrative ADSL Network Operations and Management Systems 

\ 7\ Figure 1 shows a block diagram of an illustrative ADSL network operations and 

™j management system 100. ADSL network operations and management system 100 comprises 

20 Look Qualification System (LQS) 110, Service Order Entry System (SOES) 115, Network 
Management System (NMS) 120, and Element Management System (EMS) 125. As shown, 
LQS 1 10 cooperates with SOES 1 15. In turn, SOES 115 cooperates with NMS 120, and 
NMS 120 cooperates with EMS 125. EMS 125 cooperates with ADSL Network 130 to 
communicate information from LQS 110, SOES 115, and NMS 120. In operation, LQS 110 

25 checks the feasibility (i.e. qualification) of interested subscribers' network connection and 
passes this information to SOES 115. For example, LQS 110 may verify that the location of 
the interested subscriber is within the geographic scope for the offered ADSL services. Upon 
qualification, SOES 115 procures service information about interested subscribers. The 
service information is passed to NMS 120 to begin the provisioning of resources for the 

30 interested subscriber. NMS 120 communicates with ADSL network 130 through EMS 125 to 
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communicate instructions for the configuration of PVCs that establish an end-to-end 
connection between the subscriber and ISPs/NSPs. NMS 120 creates, tracks, stores, and 
manages the PVCs for ADSL subscribers. In this capacity, NMS 120 can implement changes 
to PVC configuration. 

Illustrative ADSL Network 

Figure 2 shows a block diagram of illustrative ADSL network 200. ADSL network 
200 comprises a plurality of subscribers (207, 209, 211, 213, 215, 217) electronically coupled 
to a plurality of remote access multiplexers (RAMs) (205, 210) using ports 205a, 205b, 205c 5 
210a, 210b, and 210c, of RAMs 205 and 210, respectively. Further, ADSL network 200 
comprises a central office digital subscriber line access multiplexer (CO DSLAM 220) that 
accepts RAM outputs 205d and 210d at its input 220a and 220b, respectively. CO DSLAM 
220 is coupled at its output 220c to an asynchronous transfer mode (ATM) subnet 230 at 
input 230a of ATM sub-net. Further, the ATM sub-net 230 is coupled to Internet Service 
Providers (ISPs) / Network Service Providers (NSPs) (240 and 250). As shown, a plurality of 
subscribers are connected to RAMs 205 and 210. RAMs205 and 210 have a plurality of ports 
to accept ADSL data from subscribers. It should be appreciated that although RAMs 205 and 
210 are shown as accepting three subscribers, RAMs 205 and 210 are typically capable of 
accepting more than three subscribers. RAMs 205 and 210 act to route data to and from the 
plurality of subscribers to CO DSLAM 220 which in turn route data to ATM subnet 230 that 
communicates the subscriber data to ISPs/NSPs 240 and 250. 

In order for these ADSL network components to communicate data to and from 
subscribers, these ADSL network components require configuration. The configuration of 
ADSL network components allow ADSL network components to properly route the data to 
and from the appropriate subscribers to and from cooperating ISPs/NSPs. That is, as a 
plurality of subscribers simultaneously provide and request data from cooperating ISPs/NSPs, 
streams of data pass through these ADSL network components. These ADSL network 
components require configuration to identify which subscriber or ISP/NSP particular data 
packets are to be routed to. Accordingly, permanent virtual circuits (PVCs) are created for 
each subscriber along the ADSL network components. The PVCs are utilized to properly 
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route the data travelling over the ADSL network between subscribers and cooperating ISPs / 
NSPs. 

Provisioning of ADSL Resources (Creation of Permanent Virtual Circuits) 

In operation, the NMS (of Figure 1) (not shown), cooperates with SOES (not shown) 
and EMS (not shown) to provision resources for subscribers on the ADSL network to create 
permanent virtual circuits (PVC) between subscribers and cooperating ISPs/NSPs. A PVC 
allows data to be correctly routed between subscribers and ISPs/NSPs over the ADSL 
network. The proper communication between ADSL network components is ensured through 
the creation and assignment of configuration values among the ADSL network components 
for each subscriber. For example, exemplary ADSL network 200 comprises a RAM, a CO 
DSLAM, and ATM sub-net. The RAM must be able to communicate data packets received 
from subscribers to the CO DSLAM in such a manner that the CO DSLAM can route those 
packets correctly. Similarly, the CO DSLAM must communicate the received packets in such 
a manner that the ATM sub-net can route those packets to the appropriate ISPs/NSPs I.e., if 
subscriber SI (reference numeral 207) uses ISP/NSP 240, packets originating from subscriber 
SI must contain sufficient identifying information that they can be routed to ISP/NSP 240 
rather than ISP/NSP 250. As such, the NMS knowing the configuration schemes of these 
ADSL network components assigns and tracks configuration variables on these ADSL 
network components such that data can be properly routed. Each of the ADSL network 
components keeps track of the set configuration variables such that received data can be 
properly processed and communicated to other cooperating ADSL network components. 

Figures 2A - 2C illustrate the configuration of the various ADSL network values to 
create a permanent virtual circuit (PVC) for subscribers on an exemplary ADSL network. 
Figure 2A shows the provisioning of resources for subscriber SI (207) on RAM 205 of 
exemplary ADSL network 200 (of Figure 2). In operation, NMS 120 (shown in Figure 1) 
communicates with RAM 205 to set RAM configuration and ADSL network configuration 
variables for SI (207). As shown, at RAM port 205a, SI has the RAM input configuration 
variables Name = SI and RportID = 2. ("RportID" refers to the RAM input port to which a 
subscriber is assigned.) At the output 205 d of RAM 205, SI has the following values, Name 
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= SI, RportID2 = 2, VPI = 3, and VCI - 1 10. NMS provides RAM 205 the VPI and VCI 
values for SI. These values may be calculated according to the processing shown in Figure 3. 

Figure 2B shows the provisioning of resources on CO DSLAM 220 of exemplary 
5 ADSL network 200 (of Figure 2) for subscriber 1. As shown, output 205d of RAM 205 acts 
as input 220a to CO DSLAM 220. The values of the configuration variables at input 220a of 
CO DSLAM are as follows: Name = SI, VPI = 3, VCI = 1 10, and n -2. The VPI and VCI 
values are communicated from RAM 205 to CO DSLAM 220 for use in the creation of a 
PVC for SI. The value n represents the sequence number for RAM 205 on CO DSLAM 220. 

10 This sequence number indicates the physical connection position of RAM 205 on CO 

r3 DSLAM 220. In the example shown, n has a value of 2 since RAM 205 occupies the second 
physical connection position on CO DSLAM 220. Similar to the operation of RAM 205, CO 
-F DSLAM contributes additional values in creating the PVC for SI. In the example shown, at 

11 output 220a of CO DSLAM 220a, SI has the values, Name = SI, LPortID = 17, VPI=3, and 
lSf VCI=1 10. LPortID is the line side (i.e. CO DSLAM side) port value. This value is used in 
f conjunction with the assigned VPI and VCI values to direct data between CO DSLAM 220 
rU and ATM sub-net 230 (not shown). 

: l~g Figure 2C illustrates the completion of the PVC for SI as values are set between CO 

g DSLAM 220 and ATM sub-net 230. In the example shown, at the input of ATM sub-net 
20 230, the PVC for SI as the following values Name = SI, VPI = 3, VCI = 1 10, and NPortID = 
19. The NPortID value describes the network (i.e. ATM sub-net) port value which is used to 
transfer data to the ATM sub-net and, subsequently, to cooperating ISPs/NSPs, 240 and 250, 
respectively (not shown). As such in the example provided, subscriber (SI) is now afforded a 
connection to cooperating ISPs/NSPs over exemplary ADSL network to transfer data at will. 
25 In other words, the combination of values for the VPI (-3), VCI (=1 10), and NPortID (= 19) 
uniquely identifies the source of the packets as subscriber SI, thereby allowing ATM sub-net 
230 to correctly route those packets to the particular ISP/NSP that subscriber SI uses. 

It should be observed that VPI and VCI values are assigned relative to the particular 
RAM 205 to which SI is connected, and other RAMs (e.g., RAM 210) could assign VPI and 
30 VCI values for their subscribers independently, which would create the possibility of 



BELL-0054 (001 64) 1 5 PATENT 

It will be observed that block 340 implements the "recycling" ofyCI values. As noted in the 
example above, if there are only 991 available VCI values,Jh£n it is not possible to assign a 
unique VCI value to subscribers connected to RAMsjrf'excess of 123 (i.e., for a 124 th RAM, 
the calculation would be 33 + (124-1)*8 + Mpo^3+(124-l)*8 = 1017, which means that, 
5 according to the formula of block 320, the^fght VCI values for a 124 th RAM would range 
from 1017 through 1024, and 1024 i^/^n unacceptable value given the physical parameters of 
the system. Thus, the solution i^is to use the remainder when (n-1) is divided by (X-l). This 
essentially causes VCI vakt^s to be reused when the number of RAMs exceeds X. When VCI 
values are recycled, tt^VPI value must be changed in order to ensure that a unique VPI/VCI 

10 combination is aligned to each subscriber. For example, after the 123 rd RAM, the VPI value 
^ could be incremented by one, so that recycling of VCI values does not cause collisions among 
jfl subscribpre in the combined VPI/VCI value. 
=C Following either block 320 or 340, processing then proceeds to block 350 where a 

11 check is performed to determine whether another VCI value requires calculation . If there are 
l!5K no more VCI values than require calculation, processing terminates at block 360. However, if 
a the alternative proves to be true, processing reverts to block 300 and proceeds therefrom. 

: s 
area 

?y It should be observed that the algorithm described in Figure 3 yields at least two 

~l% distinct advantages: First, it deterministically assigns a VPI/VCI value to each subscriber 
O connected to a particular DSLAM (thereby allowing the VPI/VCI value to be recalculated 
20 easily for a given subscriber in the case of a "hung" PVC). Second, it prevents two 

subscribers on the same DSLAM from having the same VPI/VCI value. The algorithm shown 
in Figure 3 is a preferred method of accomplishing these goals, but it will be appreciated that 
other algorithms can be used to meet these goals in the assignment of VPI/VCI values. Such 
other algorithms may be substituted for that shown in Figure 3 without departing from the 
25 spirit and scope of the invention. 

In sum, the present invention provides a system and process to optimize resource 
planning for ADSL services, allowing ADSL network operators the ability to exploit 
available resources on an ADSL network. It is understood, however, that the invention is 
susceptible to various modifications and alternative constructions. There is no intention to 
30 limit the invention to the specific constructions described herein. On the contrary, the 
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invention is intended to cover all modifications, alternative constructions, and equivalents 
falling within the scope and spirit of the invention. 

It should also be noted that the present invention may be implemented in a variety of 
computer systems. The various techniques described herein may be implemented in hardware 
or software, or a combination of both. Preferably, the techniques are implemented in 
computer programs executing on programmable computers that each include a processor, a 
storage medium readable by the processor (including volatile and non-volatile memory and/or 
storage elements), at least one input device, and at least one output device. Program code is 
applied to data entered using the input device to perform the functions described above and to 
generate output information. The output information is applied to one or more output 
devices. Each program is preferably implemented in a high level procedural or object 
oriented programming language to communicate with a computer system. However, the 
programs can be implemented in assembly or machine language, if desired. In any case, the 
language may be a compiled or interpreted language. Each such computer program is 
preferably stored on a storage medium or device (e.g., ROM or magnetic disk) that is 
readable by a general or special purpose programmable computer for configuring and 
operating the computer when the storage medium or device is read by the computer to 
perform the procedures described above. The system may also be considered to be 
implemented as a computer-readable storage medium, configured with a computer program, 
where the storage medium so configured causes a computer to operate in a specific and 
predefined manner. Further, the storage elements of the exemplary computing applications 
may be relational or sequential (flat file) type computing databases that are capable of storing 
data in various combinations and configurations. 

Although exemplary embodiments of the invention has been described in detail above, 
those skilled in the art will readily appreciate that many additional modifications are possible 
in the exemplary embodiments without materially departing from the novel teachings and 
advantages of the invention. Accordingly, these and all such modifications are intended to be 
included within the scope of this invention construed in breadth and scope in accordance with 
the appended claims. 
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different subscribers having the same VPI and VCI values which, in turn, would mean that 
the combination of VPI, VCI and NPortID would not uniquely identify a subscriber. 
However, as discussed below, a feature of the invention is the assignment of VPI and VCI 
values based on the position of the input port 220a that is used to connect RAM 205 to CO 
DSLAM 220. Thus, VPI and VCI values can be assigned in such a way that every subscriber 
connected to CO DSLAM 220 has a unique VPI/VCI combination, regardless of the 
particular RAM through which such subscriber is connected to CO DSLAM 220. 

Figure 3 shows an exemplary process performed by the NMS 120 of the illustrative 
ADSL network operations and management syste^i 100 of Figure 1 to calculate the 

10 deterministic configuration variable VCI in accordance with the present invention. 

£ 3 Processing begins at block 300 and process to block 310 where a check is performed to 

^ determine if the sequence number (n) is/fess than a pre-defined number X. The pre-defined 

»p number X reflects the physical limitations of the cooperating ADSL components. In one 

j.~L example, an ADSL network maVcomprise a CO DSLAM that is capable of representing VCI 

j5; values as 10-bit integers (0-1023), and values 0-32 may be reserved for system use. In this 

f case, 991 VCI values (the/number of integers between 33 and 1023, inclusive) are available 

fy for assignment as VCLvalues for subscriber PVCs. Moreover, the exemplary ADSL network 

11 comprises RAM network components each having eight input ports. Under these parameters, 
y the pre-defined immber X is 123 (i.e. 991 subscribers divided by 8). As will be seen below, 

20 X represents^me condition that the VCI numbers must be recycled after 123 8-port RAMs are 
connected/to the DSLAM, because 8 input ports multiplied by 124 RAMs is greater than 991, 
and thus there would be insufficient numbers in the range 33-1023 to handle a 124 th 8-port 



25 [Note to Inventor: Is the above description correct and accurate?] 

If the sequence number is less than the pre-defined number X, processing proceeds to block 
320 where the VCI value is calculated using the equation: 



30 



VCI = 33 + (n-1) *8 + Mpos, 
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where: n = CO DSLAM Sequence Number ( i.e. connection position of contributing 
RAM on CO DSLAM) 

Mpos = ADSL Port Position on Contributing RAM 

5 Processing then proceeds to block 350 and therefrom. 

It will be observed that block 320 assigns VCI values to each subscriber according to 
the particular RAM to which the subscriber is connected, and also according to the 
subscriber's position on that RAM. This algorithm prevents collisions between VCI values 
for subscribers on different RAMs (up to 123 RAMs), because each RAM has its own run of 

10 eight VCI values. For example, a first RAM connected to the CO DSLAM on port sequence 
m number 1 can use VCI values 33-40 (i.e., 33 + 0*8 = 33; where Mpos can have values from 0- 
^3 7, the VCI values for that first RAM can range from 33+0 (-33) through 33+7 (=40)). 

s p Similarly, a second RAM connected on CO DSLAM port number 2 can use VCI values 41-48 
12 (i.e., 33 + 1*8 = 41; where Mpos can have values from 0-7, the VCI values for that second 
ljsj RAM can range from 41+0 (=41) through 41+7 (=48)). 

a^V^^^r Returning now to block 3 10^ it is determined that n is not less than X, processing 
rgj proceeds to block 330 where a ch^ck is performed to determine if the sequence number, n, is 

11 greater than or equal to the predetermined parameter X. If the check proves to be negative, 
Q processing terminates at block 360. However, if the sequence number is greater than or equal 

20 to the pre-determined parameter X, processing proceeds to block 340 where the VIC value is 
calculated using the following formula: 

V£I = 33 + [mod ((n-l)/(X-l))-l * 8 + Mpos, 
where: yn = CO DSLAM Sequence Number 
25 / X = Pre-defined ADSL Network Physical Parameter 

Mpos = ADSL Port Position on Contributing RAM 



{Note m Inventor: Could you please provide a paragraph or two to better define the 
variables Mpos, Dpos, and n (sequence number)?] 



